- Núcleo de PROCESSAMENTO do ARM (hardware)
- Básico de programação (Interrupções, Pilha, Funções)
- Conjunto de Instruções (ISA = Instruction Set Architecture)
- Programação ASSEMBLY para ARM Cortex

- > RESET
- Watchdog timers
- Temporizadores (timers de propósito geral e específicos)
- PWM (saída analógica ainda que usando níveis lógicos digitais)
- GPIO (General Purpose Input / Output )



♦ GPIO – pinos de entrada e saída do ARM - RESET

João Ranhel

μProcessadores e SoC geralmente podem ser resetados de várias formas. No ARM:



Circuito na placa...

µProcessadores e SoC geralmente podem ser resetados de várias formas. No ARM:

Figure 7. Simplified diagram of the reset circuit



Watchdog timers!

João Ranhel

Recordando o conceito de sub-rotina (ou chamada de função)



Recordando o conceito de sub-rotina (ou chamada de função)



μProcessadores e SoC geralmente podem ser resetados de várias formas. No ARM:

Figure 7. Simplified diagram of the reset circuit



Outras formas de reset!



> μP e SoC podem ser programados para operar em frequências desejadas...

HSI RC (8MHz) *High-Speed Internal clk* 

ARM Cortex-M3 têm 2 geradores de clk internos

LSI RC (40KHz)

Low-Speed Internal clk





μP e SoC podem ser programados para operar em frequências desejadas...

oscilador externo (cristal 4...16 MHz) *High-Speed External clk* 

oscilador externo (cristal 32.768 KHz) Low-Speed External clk





> μP e SoC podem ser programados para operar em frequências desejadas...

Multiplicador de frequência e PLL



Multiplicador? Pele... o que?





#### <u>Conceito 1</u>: VCO (Voltage-Controlled Oscillator)

VCO é um circuito que gera uma frequência de saída proporcional à tensão de controle de entrada, dentro de uma faixa pré-determinada:

4 V

| 1 57 | - NATI - |
|------|----------|
| 1 V  | 20 MHz   |

80 MHz

Por exemplo:

Conceito 2: Multiplicador de frequência...

O OUTPUT 2

Circuito que multiplica (geralmente base 2) o clock de entrada gerando frequências mais altas.

Ex: Duplicador de frequência simples, gera um pulso de saída tanto na subida quanto na descida do CK.



João Ranhel



Circuito que gera um sinal de saída cuja FASE está relacionada com a fase do sinal de entrada.

O circuito geralmente tem um VCO e um detector de fase que compara a saída do VCO com uma frequência de referência. Manter a fase de entrada e saída no "passo de bloqueio" implica manter as frequências de entrada e saída estáveis (iguais ou múltiplas uma da outra).

Exemplo: se (1) **phi\_ref** = sinal de **clock** em 8MHZ e (2) o VCO opera em 72MHz, então (3) o módulo divisor que gera φ fb deve dividir a saída do VCO por "9".

Ou seja, um sinal de 8MHz serve de referência para o VCO do circuito PLL gerar 72 MHz de forma estável.



μP e SoC podem ser programados para operar em frequências desejadas...

Multiplicador de frequência e PLL





μP e SoC podem ser programados para operar em frequências desejadas...

#### **CLOCK GATES**

(as que temos que programar para habilitar os clocks nos periféricos)!





> μP e SoC podem ser programados para operar em frequências desejadas...

#### **PRESCALERS**

(divisores do clock SYSCLK para adequar a frequência para os timers, ADC, etc...)





Figure 2. Clock tree > μP e SoC podem to Flash programming interface 8 MHz HSI HSI RC ser programados para USBCLK USB 48 MHz to USB interface Prescaler operar em frequências /1, 1.5 HCLK 72 MHz max to AHB bus, core, desejadas... memory and DMA Enable (3 bits) → to Cortex System timer PLLSRC PLLMUL ► FCLK Cortex free running clock HSI AHB APB1 ..., x16 SYSCLE 36 MHz max [ Prescaler Prescaler x2, x3, x4 PLLCLK PLL /1, 2..512 /1, 2, 4, 8, 16 peripherals Peripheral Clock HSE Enable (13 bits) to TIM2, 3 TIM2,3,4 If (APB1 prescaler =1) x1 CSS Peripheral Clock Enable (3 bits) APB2 PLLXTPRE 72 MHz max Prescaler OSC OUT 1, 2, 4, 8, 16 4-16 MHz peripherals Peripheral Clock HSE OSC Enable (11 bits) OSC IN 12 TIM1 timer to TIM1 If (APB2 prescaler =1) x1 else **TIMERs** Peripheral Clock 128 Enable (1 bit) ADC to ADC (nosso próximo OSC32 IN to RTC Prescaler LSE OSC LSE **ADCCLK** RTCCLK 12, 4, 6, 8 32.768 kHz assunto...) OSC32\_OUT RTCSEL[1:0] to Independent Watchdog (IWDG) LSI LSI RC 40 kHz **IWDGCLK** HSE = high-speed external clock signal HSI = high-speed internal clock signal -PLLCLK LSI = low-speed internal clock signal Clock Output LSE = low-speed external clock signal MCO HSI -HSE SYSCLK STM32F103C8 Datasheet CD00161566 MCO



 $\diamondsuit$  Timers do processador ARM Cortex

- timers são contadores que operam paralelo à CPU gerando bases temporais para o sistema.
- ➤ ARM tem até 16 timers de uso geral (STM32F103C8 tem 4 timers)
- são independentes e podem contar UP, DOWN ou UP-DOWN
- Systick é um timer dedicado 24 bits (já usamos para criar base de tempo 1 ms)

### Esquema básico de um timer no Cortex-M:





♦ Timers do processador ARM Cortex



Modo COMPARAÇÃO (compara o timer counter com o valor de um registrador CCR):

- → usado para gerar interrupções
- → usado para saída PWM (veremos PWM adiante...)







## PWM tem sido usado como *saída analógica* em SoC e em μControladores.

PWM: Gera sinais com relação pwm\_out temporal entre níveis lógicos '1' e '0' controlados e bem definidos.

25% duty cycle - average pwm\_o is 1.25V

Ciclo de trabalho (duty cycle): % tempo do sinal 'alto' (1) em relação ao sinal 'baixo' (0) Onda quadrada: ciclo de 50%

pwm\_out

pwm out

clk

clk

Usos comuns: controlar tensão média para o dispositivo elétrico:



Velocidade de motor DC, dimmers



50% duty cycle - average pwm\_o is 2.5V.

Outro uso: comandos codificados temporalmente, onde o receptor usa temporizador para decodificar sinal recebido.



75% duty cycle – average pwm\_o is 3.75V.



# Construindo um *PWM Digital* – (processador pwm)





## Construindo um *PWM Digital* – (processador pwm)





#### PCA-9685:

## 16-channel, 12-bit PWM Fm+ I<sup>2</sup>C-bus LED controller

(custo Digikey: US\$ 1,06 p/ 2500 peças)





### Placa Adafruit:

( custo: ~US\$ 15 por placa ) ( genérica chinesa: US\$ 8 ) Como µControladores têm mais funções que pinos de I/O os fabricantes atribuem mais de uma função a cada pino. A funcionalidade do pino deve ser programada.

Figure 13. Basic structure of a standard I/O port bit



João Ranhel

Como µControladores têm mais funções que pinos de I/O os fabricantes atribuem mais de uma função a cada pino. A funcionalidade do pino deve ser programada.

Cada pino de GPIO no ARM Cortex pode ser configurado nos modos:

- Input floating
- Input pull-up
- Input-pull-down
- (Input) Analog
- Output open-drain
- Output push-pull
- > Alternate function push-pull
- Alternate function open-drain
- ✓ Cada bit de porta de I/O é livremente programável, porém, os registros de porta de I/O devem ser acessados como palavras de 32 bits (não são permitidos acessos de meia palavra ou de byte).
- ✓ Durante e logo após o reset as funções alternativas ficam INATIVAS e as portas de I/O são configuradas no modo de entrada flutuante.

Alguns pinos do CI são tolerantes à excitação de 5V (lógica de 5V)...

Figure 14. Basic structure of a five-volt tolerant I/O port bit



V<sub>DD\_FT</sub> is a potential specific to five-volt tolerant I/Os and different from V<sub>DD</sub>.

 Quando os pinos não são usados como GPIO devem ser configurados p/ modo de funções alternativas (exemplo: saída PWM – referenciada como AFIOs)

Figure 17. Alternate function configuration



(um dos 4 canais de um TIMERx)

Esta é uma estrutura básica para INPUT digital...

Figure 15. Input floating/pull up/pull down configurations



Esta é uma estrutura básica para OUTPUT digital...

Figure 16. Output configuration



Esta é uma estrutura básica para OUTPUT digital...



- Circuito de RESET
- Conceito de Watchdog timers
- ➤ Circuito de CLOCK do ARM programador de clock
- Duplicadores de frequência, divisores de frequência, e PLL
- > Timers como são estruturados e configurados os timers do ARM Cortex
- PWM pulse width modulation (uma saída analógica dos μC e SoC)
- Configuração dos pinos de entrada e saída do CI (GPIOs)
- Configuração dos pinos para SAÍDA, ENTRADA, função ALTERNATIVA e entrada ANALÓGICA.